import axios, { type Method } from 'axios'
import { showToast } from 'vant'
import router from '@/router'
import { useUserStore } from '@/stores'

const baseURL = 'https://consult-api.itheima.net/'
const instance = axios.create({
  baseURL,
  timeout: 5000
})

// 请求拦截器
instance.interceptors.request.use(
  (config) => {
    const store = useUserStore()
    if (store.user?.token) {
      config.headers.Authorization = store.user.token
    }
    return config
  },
  (err) => {
    return Promise.reject(err)
  }
)

// 响应拦截器
instance.interceptors.response.use(
  (res) => {
    if (res.data.code !== 10000) {
      // TODO: 测试请求成功数据失败
      // 请求成功,数据失败
      showToast({
        message: res.data.message || '请求失败',
        icon: 'none'
      })
      return Promise.reject()
    }
    // 完全成功
    return res.data
  },
  (err) => {
    if (err.response.status === 401) {
      // TODO: 测试 token 失效
      // 删除用户信息
      const store = useUserStore()
      store.delUser()
      // 跳转登录，带上接口失效所在页面的地址，登录完成后回跳使用
      router.push({
        path: '/login',
        query: { returnUrl: router.currentRoute.value.fullPath }
      })
    }
    // TODO: 测试完全失败
    return Promise.reject(err)
  }
)

// 因为每次写泛型很麻烦, 希望可以封装装一个函数处理
// 所有请求数据的结构
type Data<T> = {
  code: number
  message: string
  data: T
}
// 函数的封装
const request = async <T>(
  url: string,
  method: Method = 'get',
  data?: object
) => {
  const dataKey = method.toLowerCase() === 'get' ? 'params' : 'data'
  return instance<T, Data<T>>({
    url,
    method,
    [dataKey]: data
  })
}

export { baseURL, instance, request }
